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A METHOD FOR INDEXING FEATURE VECTOR DATA SPACE 

BACKGROUND OF THE INVENTION 

1 . Field of the Invention 

The present application claims the benefit under 35 U.S.C. § 
1 19(e) of the filing date of U.S. Provisional Application No. 60/226,586, 
5 filed August 21 , 2000 and entitled "A Scabel and Adaptive Index 

Structure For Similarity Search in High Dimensions". The contents of 
this U.S. Provisional Application are incorporated herein by reference. 

The present invention relates to a method for indexing feature 
vector data space, and more particularly, to a method for indexing 
10 feature vector data space which efficiently performs indexing within the 
vector space having high-dimensionality in which feature vectors are 
not uniformly distributed. 

The present application also claims the benefit under 35 
U.S.C. § 1 19(a) of the filing date of Korean Patent Application No. 00- 
15 58759 which is incorporated herein by reference. 

2. Description of the Related Art 

High dimensionality of typical multimedia data descriptors pose 
challenging problems in designing efficient indexing schemes. 
Therefore, several new indexing structures have been proposed 

20 recently. One of the common assumptions made is that feature 

vectors in the high dimensional feature space are uniformly distributed 
within a vector space. However, many media descriptors, such as 
image texture descriptors, are not uniformly distributed. For example, 
in the case of a method for using well-known vector approximation (VA) 

25 files, the performance of the method depends on the uniform 
distribution of the feature vectors. 




Generally, the method of the related art suffers because its 
performance abruptly drops when indexing the feature vector data 
within vector space having high-dimensionality, in which the feature 
vectors are not uniformly distributed. 

5 SUMMARY OF THE INVENTION 

To solve the above problems, it is an object of the present 
invention to provide a method for indexing feature vector data space 
which performs indexing efficiently within vector space having high- 
dimensionality, in which the feature vectors are not uniformly 
10 distributed. 

To achieve the above objective according to the present 
invention, there is provided a method for indexing feature vector data 
space including a step of: (a) indexing feature vector space by 
adaptively approximating feature vectors on the basis of statistical 
15 distribution of feature vector data in the feature vector data space. 

Step (a) further includes the steps of:(a-1) measuring the 
statistical distribution of the feature vector data in the feature vector 
data space; (a-2) estimating marginal distribution of the data using the 
statical distribution;(a-3) dividing the estimated distribution into a 
20 plurality of grids in which a distribution of disposing the data in each 

grid becomes uniform; and (a-4) indexing the feature vector data space 
using the divided grids. 

Prior to step (a-4), it is preferable to further include a step of 
updating the grids on the basis of the previous probability distribution 
25 function and the updated probability distribution function, when new 
data is entered. 

Also, step (a-4) preferably further includes a step of indexing 
using vector approximation (VA) files. 

In a preferred embodiment, the number of the plurality of grids is 
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determined by the number of bits assigned to the dimension. 

Step (a-2) further includes the steps of: (a-2-1 ) defining the 
probability distribution function using a weighted sum of the 
predetermined distribution function; and (a-2-2) obtaining the estimated 
5 probability distribution function by estimating the predetermined 

parameters using the probability distribution function defined in the step 
(a-2-1). 

Step (a-2-2) further includes a step of obtaining an estimated 
probability distribution function by estimating parameters using all N 
10 predetermined data, wherein N is a positive integer, for several 

iterations on the basis of the expectation-maximization algorithm and 
using the probability distribution function defined in the step (a-2-1). 

Also, preferably, the predetermined distribution function is a 
Gaussian function. 

15 In a preferred embodiment, the probability distribution function of 

step (a-2-1) is a one-dimensional signal, p(x), wherein 

N 

p(x) = ^p(x\j)P (J) , and wherein p(x\j) is defined as 

1 f (x-uY\ 
p ^ x \j> }= ^^ =re xp\-- — ^— \ , wherein coefficient PQ) is a mixing 

parameter that satisfies certain criterion. 
20 In another preferred embodiment, the estimated probability 
function of step (a-2-2) is obtained by finding Oj, j=1 M. which 

N 

maximizes ^(Oi, ...,0 M )=n/ ? ( v t / l|( 0 /'-- <I) ^)) ■ wherein parameters 

/=0 

v[l] ,1=1, ...A/, is a given data set. 
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In a further embodiment, the estimated parameters of step (a-2- 

|>a|v[/])'v[/] 

2) are updated according to //'f 1 =Jj± n • 

ZpO|v[/])' 

Y,pu\A.n)'W]-M)) 2 
£^o|v[/])' 

5 representing the number of iteration. 

Also, preferably, the estimated parameters set of step (a-2-2) 
used N data v[l], given as {P(j) N }- and the updated 

parameter set for new data v[N+1] coming in, is calculated using the 
following equations: 

10 = + or w N + - ) • 

to*)"* 1 ={ct)) n +< +i [(v[^ + 1]-//;) 2 -(a*)"], 

PU) N+l =PU) N +77^-7 (piMN + l]-PUr), and 
N + 1 1 

^ ' ' + j 

Step (a-2-2) also further includes the steps of: measuring 
15 changes of the probability function which is defined as 
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— — ^ Po ' d ^ — Pnew( x )) for each c jj mens j onj wherein the previous 

A 

probability distribution function is p old (x) and the updated probability 

distribution function is p new (x), and updating an approximation for the 

dimension if p is larger than a predetermined threshold value. 
5 In a preferred embodiment, step (a-3) also includes a step of 

dividing the probability distribution function into the plurality of grids to 
make areas covered by each grid equal, wherein the plurality of grids 
have boundary points defined by c[l] f I = 0,..,2 b , where b is a number of 
bits allocated, and wherein the boundary points satisfy a criterion, 

A "I A 

10 i c c l [t] 1] p(x)dx = ^-^[oJ ] p(*)dx , and wherein the estimated probability 
distribution function is p(x). 

BRIEF DESCRIPTION OF THE DRAWINGS 
The above objective(s) and advantages of the present invention 
will become more apparent by describing in detail a preferred 
15 embodiment thereof with reference to the attached drawings in which: 
FIG. 1 is a flowchart showing the main steps of an indexing 
method according to the preferred embodiments of the present 
invention; 
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FIG. 2 illustrates a case where data joint distribution is still not 
uniform but agglomerated even though the marginal distribution of the 
data is uniform in each dimension; 

FIG. 3A is a histogram showing the distribution of feature vector 
5 data within the feature vector data space; 

FIG. 3B is a graph showing the probability distribution function 
estimate on the histogram; 

FIG. 4A is a graph showing feature vector values of the data 

sets; 

10 FIG. 4B is a graph showing the results of calculating a histogram 

of the data sets of FIG. 4A; 

FIGS. 4C, 4D, and 4E are graphs showing the estimated 
probability distribution functions when the number of elements used for 
the estimation is 1700, 3400, and 5000, respectively; 

15 FIGS. 5A and 5B are graphs showing the comparison of the 

number of feature vectors visited in first and second filtering steps, 
using a conventional indexing method and an indexing method of the 
present invention. 

DETAILED DESCRIPTION OF THE INVENTION 
20 Hereinafter, preferred embodiments of the present invention will 

be described with reference to the appended drawings. 
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FIG. 1 is a flowchart illustrating the main steps of an indexing 
method according to a preferred embodiment of the present invention. 
According to the present invention, vector approximation (VA) files are 
adaptively formed on the basis of statistical distributions of feature 
5 vector data within the feature vector data space. 

That is, since densely distributed cells can deteriorate the 
performance of indexing, the approximation of the feature vectors is 
adaptively formed according to statistical features of the data in the 
present invention. To do this according to the indexing method as 

10 shown in Figure 1 , statistical distributions of the feature vector data are 
measured within the feature vector data space (step 102). Then, 
marginal distribution is estimated using the statistical distribution (step 
104). Next, estimated marginal distributions are divided into a plurality 
of grids in which a probability of disposing the data in each grid 

15 becomes uniform (step 106) and wherein the number of grids is 

determined by the number of bits assigned to the dimension. Then, the 
feature vector data space is indexed using the divided grids (step 108). 
Step 108 can be performed on the basis of the indexing method using 
well known vector approximation (VA) files. 

20 The approximation formed by the above method reduces the 

possibility of having densely distributed cells. Therefore, the 
performance of indexing is enhanced. It should be noted, however, 
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that the marginal distributions of the data can only capture partial 
information of high dimensional distributions. 

FIG. 2 illustrates a case where the point distribution of data is 
agglomerated rather than uniform, even though the marginal 
5 distributions of the data are uniform in each dimension. With reference 
to FIG. 2, the marginal distributions of the data are uniform in each 
dimension within the entire feature vector data space 20. Considering, 
however, that the correlation of data on different dimensions decreases 
with an increase of data's dimensionality and the attributes of 

10 image/video database, capturing the statistical properties of the high 
dimensional data can still be an effective method for estimating the 
marginal distributions of the data. 

Hereinafter, techniques for realizing a method of the present 
invention will be described in greater detail. First, a probability 

15 distribution function is denoted by pj(x) for data on dimension /. 
Following the assumption that data on each dimension are 
independent of each other, the algorithm described hereinafter can be 
applied to each dimension independently. 

Also, as previously described, the data distribution is not 

20 uniform. In fact, the probability distribution function of data may be 

irregular or incapable of being modeled by a well-defined function such 
as, for example, the Gaussian function. To overcome this deficiency, 
the present invention provides a probability distribution function of one- 



dimensional data that is modeled using the Gaussian mixture function 
in order to endure a change of the data distribution. 

First, it is assumed that a probability distribution function of a 
one-dimensional signal, p(x) is defined as follows: 



p(x) = ^p(x\j)P(j) ...(1) 



Here, the p(x\j) is defined as follows. 



J)= ^ e T^r^ • <2) 



J 



The coefficients P(j) are mixing parameters, which satisfy the criteria 
0<P(j)^l and the following formula. 

10 f>0*) = i ■■■( 3 ) 

Thus, in this embodiment, the probability distribution function is defined 
using a weighted sum of the Gaussain function. Then, the task of 
estimating the probability distribution function is converted to an 
exercise of parameter estimation for the parameters ^ = {P(j), juj, o?}, 
15 fory=1,...M. 
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A maximum likelihood based method is used for the parameter 



estimation using the idea that the optimal estimation of parameters 



should result in a probability distribution function which most likely 
would give rise to given data. In this case, we want to find 4,7=1, ...M 
5 to maximize 



where v[i], /=1, ... A/, are the given data set. 

The above parameters are obtained using an expectation- 
maximization (EM) algorithm. According to the EM algorithm, N 
10 predetermined data are inputted for the estimation, and parameters are 
estimated iteratively using all the N given data in each iteration. 

The following equations are used to update the estimated 
parameters, where t denotes the iteration number, 



N 



0(0, o M ) = n pwt^ '•••> » 



...(4) 





...(5) 



i>(y|v[/])' 

1=1 



£X/|v[/])'(v[/]-//p 2 



15 





N 



...(6) 



i=i 
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However, the above formulas may cause a crash of estimation if 
the data's distribution has a singular value which can not be grouped 
with other values as a part of a Gaussian function. 

When this is the case, in order to capture a value accurately, ji 
5 must be allowed to approach the singular value and the corresponding 
a 2 must converge to 0. To avoid this singularity problem, a very small 
value is set as a lower bound for an estimated variance. 

In order to explain the efficiency of using the EM algorithm for 
estimating parameters of the Gaussian mixture function, a histogram 
10 illustrating a distribution of feature vector data within the feature vector 
data space in provided in FIG. 3A, and a graph of a probability 
distribution function estimation based on the histogram is illustrated in 
FIG. 3B. 

As shown in FIGs. 3A and 3B, a data's probability distribution 
15 function can be modeled well using the Gaussian mixtures as the 

modeling tool and the EM algorithm to estimate the parameters, even 
though the data's distribution is irregular and cannot be modeled by 
some simple form function. 

The parameters may also be updated by on-line estimation 
20 using the formulas of equations 5, 6, and 7 if N predetermined data are 
available. In the case of a large database, N is generally only a small 
portion of the total number of elements in the database. 
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In realistic database applications, an estimation is required to be 
updated at a prescribed point. For example, there may be a case 
where a larger portion of data is required for a better estimation. 
Alternatively, when the database is non-static, the probability 
distribution function must be re-estimated because the statistical 
characteristics of data change. In any case, a "memory" of the 
previous estimation is not required to be totally erased. 

In view of the parameter estimation, a strategy must be provided 
for tracking the change of the estimated probability distribution function 
when a data set is changing. For this purpose, an algorithm is 
provided in the present invention which can sequentially update the 
estimation. 

Given that {P(j) N M)) N ) is the parameter set estimated 
using N data v[l], the updated parameter set, when there is new data 
v[N+1] coming in, is calculated as follows. 




=//;+^r(v[^+i]-//; 



...(8) 



i 



N + l 



In the formulas 8 and 9, 




P(j\v[M]) 



(^r'+i ...(11) 



PU\v[N + l]) 
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In order to evaluate the tracking performance using on-line 
estimation, experimentation was performed on a synthetic data set. 
The feature vector values of data sets are illustrated in FIG. 4A and 
include 5,000 elements. 
5 FIG. 4B shows the results of calculating histograms for the data 

sets of FIG. 4A. Each individual element is sequentially added for the 
estimation. Then, the parameters are calculated using formulas 8, 9 
and 10. Next, the probability distribution function is reconstructed from 
the estimated parameters, when a certain number of elements are 

10 used for the estimation. 

FIGS. 4C, 4D, and 4E show the estimated probability distribution 
functions when the number of elements used for the estimation is 
1700, 3400, and 5000, respectively. Referring to FIGS. 4C, 4D, and 
4E, when the distribution of input data changes, it is shown that the on- 

15 line estimation tracks very well. It is noted that the effectiveness of the 
on-line estimation partially depends on the method of choosing data as 
an input. 

For example, if one wants to estimate the probability distribution 
function of the data as shown in FIG. 4A, but the data is chosen in the 
20 same order as they are indexed, then one can only have the estimated 
probability distribution function shown in FIG. 4E. Thus, the data 
should ideally be chosen unbiased. 
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Next, nonlinear quantization is applied to segment a probability 
distribution function into a plurality of grids to make areas covered by 
each grid equal, wherein the estimated probability distribution function 

A 

is called p(x) . The boundary points are indicated by c[/|, / = 0,...,2 b , 
5 where b is the number of bits allocated, wherein the boundary points 
should satisfy the following criterion: 

i$n } kx)dx~l$y P ix)dx -..(12) 

Using this criterion, it is possible to determine boundary points from 
one pass scan of the estimated probability distribution function. For 

10 example, the boundary points of each dimension are determined by 
agglomerating all the N data into 2 b clusters. In addition to being 
computationally efficient for determining boundary points, equation 12 
also avoids dependency on distance measurements. 

According to the above method, a probability distribution 

15 function is able to be updated. This feature is very important for 

maintaining the indexing of a non static database. That is, every time a 
previous estimation does not fit with the updated estimation, the 
approximation also needs to be updated. 

For this reason, a measure is required to decide when to update 

20 the approximation based on the change of probability distribution 

function estimation. As a result of the parallel scheme of utilizing the 
probability distribution function to construct the approximation, the 

14 



measure for updating the approximation can be defined on each 
dimension. 

If the previous probability distribution function is denoted p old {x) 

A 

and the updated probability distribution function is denoted p new (x), a 
measurement of change of the probability distribution function can be 
defined as follows. 

p = \{Pold (X) - Pnewjx)) 2 dx ^ ^ 

\Poid(x) 2 dx 

The approximation for a dimension is updated when p is bigger 
than a predetermined threshold value. 

An experiment was performed for evaluating an image database 
having 34,698 aerial photograph images. First, 48-dimensional feature 
vectors describing texture characteristics of each of the images were 
extracted using a predetermined method for extracting texture features. 
A probability distribution function was estimated from an entire data set 
on the basis of the extracted feature vector. 

FIGS. 5A and 5B show a comparison of the number of feature 
vectors which visit in the first step filtering and the second step filtering, 
using the conventional indexing method and the indexing method of the 
present invention. 
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In FIG. 5A, a graph 502 shows the number of feature vectors 
which visit in the first filtering step using the indexing method of the 
present invention which adaptively forms VA files, and a graph 504 
shows the number of feature vectors which visit in the first step filtering 
5 using the conventional indexing method which uses fixed VA files. The 
number of feature vectors which visit in the first step filtering is also 
indicated as a vertical axis of N1 . 

In FIG. 5B, a graph 512 shows the number of feature vectors 
which visit in the second filtering step using the indexing method of the 

10 present invention which adaptively forms VA files, and a graph 514 
shows the number of feature vectors which visit in the second step 
filtering using the conventional indexing method which uses fixed VA 
files. The number of feature vectors which visit in the second step 
filtering is also indicated as a vertical axis of N2. 

15 Comparing graphs 502 and 504 with the graphs 512 and 514, 

the number of feature vectors, which visit in the first step filtering and 
the second step filtering using the indexing method of the present 
invention which forms adaptively VA files, is much larger than the 
number of feature vectors which visit in the first step filtering and the 

20 second step filtering using the conventional indexing method which 
uses fixed VA files. 

The indexing method of the present invention may be written as 
a program which is performed in a personal computer or a server 
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computer. Program codes and code segments which form the program 
can be easily derived by computer programmers in the art. Also, the 
program can be stored in computer readable recording media. The 
recording media includes magnetic recording media, optical recording 
media, and carrier wave media. 

While a specific embodiment of the invention has been shown 
and described in detail, it will be understood that the invention may be 
modified without departing from the spirit of the inventive principles as 
set forth in the hereafter appended claims. 
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